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(57) Abstract 



A firewall is used to achieve network separation within a computing system having a plurality of network interfaces. A plurality 
of regions is defined within the firewall and a set of policies is configured for each of the plurality of regions. The firewall restricts 
communication to and from each of the plurality of network interfaces in accordance with the set of policies configured for the one of the 
plurality of regions to which the one of the plurality of network interfaces has been assigned. 
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SYSTEM AND METHOD FOR CONTROLLING 
INTERACTIONS BETWEEN NETWORKS 

5 

fiVIH nf the Invention 

The present invention relates generally to network security, and 
more particularly to a system and method of grouping networks to enforce a 
security policy. 

10 .Background of the Invention 

Recent developments in technology have made access easier to 
publicly available computer networks, such as the Internet. Organizations are 
increasingly turning to external networks such as the Internet to foster 
communication between employees, suppliers and clients. With this increased 

15 access comes an increased vulnerability to malicious activities on the part of 
both people inside and outside the organization. Firewalls have become a key 
tool in controlling the flow of data between internal networks and these external 
networks. 

A firewall is a system which enforces a security policy on 
20 communication traffic entering and leaving an internal network. Firewalls are 
generally developed on one or more of three models: the screening router, the 
bastion host, and the dual homed gateway. These models are described in U.S. 
Patent No. 5,623,601 to Vu, issued April 22, 1997 and entitled APPARATUS 
AND METHOD FOR PROVIDING A SECURE GATEWAY FOR 
25 COMMUNICATION AND DATA EXCHANGES BETWEEN NETWORKS 
(Vu), which is hereby incorporated herein by reference. 

Vu describes packet filters as a more sophisticated type of 
screening that operates on the protocol level. Packet filters are generally host- 
based applications which permit certain communications over predefined ports. 
30 Packet filters may have associated rule bases and operate on the principle of that 
which is not expressly permitted is prohibited. Public networks such as the 
Internet operate in TCP/IP protocol. A UNIX operating system running TCP/IP 
has a capacity of 64K communication ports. It is therefore generally considered 
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impractical to construct and maintain a comprehensive rule base for a packet 
filter application. Besides, packet filtering is implemented using the simple 
Internet Protocol (IP) packet filtering mechanisms which are not regarded as 
being robust enough to permit the implementation of an adequate level of 
5 protection. The principal drawback of packet filters, according to Vu, is that 
they are executed by the operating system kernel and there is a limited capacity 
at that level to perform screening functions. As noted above, protocols may be 
piggybacked to either bypass or fool packet filtering mechanisms and may 
permit skilled intruders to access the private network. 
10 Accordingly, H is an object of this invention is to provide a 

method for controlling interactions between networks by the use of firewalls 
with defined regions. 

Summar y of the Invention 

The present invention is directed to a system and method of 

1 5 achieving network separation within a computing system having a plurality of 
network interfaces. One aspect of the invention is a method comprising the steps 
of defining a plurality of regions; configuring a set of policies for each of the 
plurality of regions; assigning each of the plurality of network interfaces to only 
one of the plurality of regions, wherein at least one of the plurality of network 

20 interfaces is assigned to a particular region; and restricting communication to 
and from each of the plurality of network interfaces in accordance with the set of 
policies configured for the one of the plurality of regions to which the one of the 
plurality of network interfaces has been assigned. 

Another aspect of the invention is a secure server comprising an 

25 operating system kernel; a plurality of network interfaces which communicate 
with the operating system kernel; and a firewall comprising a plurality of 
regions, wherein a set of policies have been configured for each of the plurality 
of regions; wherein each of the plurality of network interfaces is assigned to only 
one of the plurality of regions; wherein at least one of the plurality of network 

30 interfaces is assigned to a particular region; and wherein communication to and 
from each of the plurality of network interfaces is restricted in accordance with 
the set of policies configured for the one of the plurality of regions to which the 
one of the plurality of network interfaces has been assigned. 
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A feature of the present invention is the application level 
approach to security enforcement, wherein type enforcement is integral to the 
operating system. Still another feature is protection against attacks including 
intruders into the computer system. Yet another feature is a new graphical user 
5 interface (GUI) in effective Access Control Language (ACL). A further feature 
of the present invention is a visual access control system. Another feature is 
embedded support for Virtual Private Networking (VPN). 

Rrief Description of the Drawings 
Figure 1 depicts an implementation of the firewall of the present invention. 
0 Figure la shows a representative computing system protected by a firewall. 
Figure lb depicts another computing system protected by a firewall. 
Figure 2 shows the regions and their members as defined in the present 
invention. 

Figure 3 is a graphical representation of ACL commands. 

5 Figure 4 is a flow diagram for a virus alert. 

Figure 5 depicts a method by which incoming data packets are processed 
in accordance with the present invention. 
Detailed Descrip ti on of the Preferred Embodiments 
In the following detailed description of the preferred 

) embodiments, reference is made to the accompanying drawings which form a 
part hereof, and in which is shown by way of illustration specific embodiments 
in which the invention may be practiced. It is to be understood that other 
embodiments may be utilized and structural changes may be made without 
departing from the scope of the present invention. 

) Figure 1 depicts a block diagram showing the relationship 

between a firewall 34 in accordance with this invention, the Internet 36, a Secure 
Server Network (SSN) 38, a Company Private Net 40, and a Partner Shared Net 
42. As shown in Figure 1 , communications to and from any other servers or 
networks goes through the firewall 34. 

) Two representative firewall-protected computing systems are 

shown in Figures la and lb. System 10 in Figure la includes an internal 
network 12 connected through firewall 14 to external network 16. A server 18 
and one or more workstations 20 are connected to internal network 12 and 
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communicate through firewall 14 with servers or workstations on external 
network 16. 

System 30 in Figure lb includes an internal network 32 connected 
through firewall 34 to external network 36. A server 38 and one or more 
5 workstations 40 are connected to internal network 32. In addition, a server 42 is 
connected through network 44 to firewall 34. Workstations 40 communicate 
through firewall 14 with servers or workstations on external network 16 and with 
server 42 on network 44. In one embodiment network 44 and server 42 are in a 
sort of demilitarized zone (DMZ) providing protected access to server 42 to 

10 internal users and to external entities. 

In one embodiment, firewalls 14 and 34 implement a 
region-based security system as will be discussed below. 

Regions are a new and flexible way of organizing systems such as 
systems 10 and 30. Regions let you group both physical interfaces (network 

15 cards) and Virtual Private Networks (VPNs) into areas of similar trust and 

security needs. Regions (along with services) provide the foundation on which 
every access rule is built. By grouping together networks and VPNs that require 
the same type of security, you eliminate the need to enter multiple versions of 
the same access rule for each network or VPN. In doing so, regions give you the 

20 flexibility to tailor a security policy that meets the specific needs of your 
network environment. 

One embodiment of a region-based system is shown in Figure 1 . 
In Fig. 1, firewall 34 coordinates communication between internal network 32 
(e.g., a company private network), external network 36 (e.g., the Internet) and 

25 DMZ network 44 (e.g., a secure server network). In one such embodiment, 

firewall 34 also controls virtual private network (VPN) communication between 
external entities and networks 32 and 44. Regions are defined and one or more 
networks is assigned to each region. In the example shown in Figure 3 f the 
regions are Sales Office, Worldwide Customer Service, Worldwide Sales, Secure 

30 'DMZ 1 and R&D Network. R&D Network includes the trusted internal network. 
Sales Office and Secure 'DMZ' are within slightly less trusted regions. 
Worldwide Customer Service and Worldwide Sales come in unencrypted over 
the Internet and are, therefore, the least trusted. 
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Firewall 34 protects regions from unauthorized access through the 
use of access rules. For each connection attempt, the Firewall checks it against 
the defined access rules. The rule that matches the characteristics of the 
connection request is used to determine whether the connection should be 
5 allowed or denied. 

The operating system on which the firewall 34 is implemented is 
the BSDI 3.1 version of UNIX, a security hardened operating system with each 
application separated out, and protected by type enforcement technology. The 
functions of firewall 34 are all integrated with the operating system, and each 

10 one is completely compartmentalized and secured on its own, and then bound by 
type enforcement control. 

Type enforcement, which is implemented within the operating 
system itself, assures a very high level of security by dividing the entire firewall 
into domains and file types. Domains are restricted environments for 

15 applications, such as FTP and Telnet. A domain is set up to handle one kind of 
application only /and that application runs solely in its own domain. File types 
are named groups of files and subdirectories. A type can include any number of 
files, but each file on the system belongs to only one type. 

There is no concept of a root super-user with overall control. 

20 Type enforcement is based on the security principle of least privilege: any 
program executing on the system is given only the resources and privileges it 
needs to accomplish its tasks. On the firewall of this invention, type 
enforcement enforces the least privilege concept by controlling all the 
interactions between domains and file types. Domains must have explicit 

25 permission to access specific file types, communicate with other domains, or 
access system functions. Any attempts to the contrary fail as if the files did not 
exist. The type enforcement policy is mandatory, and nothing short of shutting 
the system down and recompiling the type enforcement policy database can 
change it. 

30 Type enforcement is described in two pending patent applications 

entitled SYSTEM AND METHOD FOR PROVIDING SECURE 
INTERNETWORK SERVICES, Serial No. 08/322,078, filed October 12, 1994, 
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and SYSTEM AND METHOD FOR ACHIEVING NETWORK SEPARATION, 
Serial No. 08/599,232, filed February 9, 1996. 

Essentially, a type enforcement scheme provides for the secure 
transfer of data between a workstation connected to a private network and a 

5 remote computer connected to an unsecured network. A secure computer is 
inserted into the private network to serve as the gateway to the unsecured 
network and a client subsystem is added to the workstation in order to control the 
transfer of data from the workstation to the secure computer. The secure 
computer includes a private network interface connected to the private network, 

0 an unsecured network interface connected to the unsecured network, wherein the 
unsecured network interface includes means for encrypting data to be transferred 
from the first workstation to the remote computer, a server function for 
transferring data between the private network interface and the unsecured 
network interface and a filter function for filtering data transferred between the 

5 remote computer and the workstation. 

The firewall of the present invention features application-level 
gateways, which negotiate communications and never make a direct connection 
between two different networks. Hence, unlike packet filtering, which, as 
described in the prior art, applies rules on every incoming packet of data, the 

) firewall applies rules applicable to the network or port in which data packets are 
entering. The gateways have a detailed understanding of the networking services 
they manage. This architecture isolates activity between network interfaces by 
shutting off all direct communication between them. Instead, application data is 
transferred in a sanitized form, between the opposite sides of the gateway. 

5 In addition to the firewall's secured type enforced operating 

system and application gateway architecture, the system has been designed to 
defend against known network penetration and denial of service attacks. 

Finding out who and where attacks are originating from is a key 
requirement to taking corrective action. The firewall also includes intruder 

[) response that allows administrators to obtain all the information available about 
a potential intruder. If an attack is detected or an alarm is triggered, the intruder 
response mechanism collects information on the attacker, their source, and the 
route they are using to reach the system. 
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In addition to real-time response via pager or SNMP, alarms can 
be configured to automatically print results or to email them to the designated 
person. 

The growing need for applying specific security policies and 
5 access requirements to complex organizations requires a new way of managing 
firewalls - regions. Regions are groupings of physical interfaces (network cards) 
and virtual networks (VPNs) into entities of similar trust. 

Suppose a company has thousands of roaming users connecting to 
the company network from encrypted virtual private network ("VPN") clients - 

1 0 managing such users one at a time would be an enormous task. It would be 
easier to organize those roaming users into groups having, as an example, full 
access, medium access, and limited access rights. Figure 2 depicts regions 
Internet, Secure ? DMZ\ R&D Network, Sales Offices, Worldwide Customer 
Service, and Worldwide Sales. In Figure 2, all Sales or Customer Support 

15 departments in the company's offices can be grouped together into regions 
Worldwide Sales%nd Worldwide Customer Service, respectively. 

Regions permit the grouping of networks and VPNs that require 
the same type of security, thereby eliminating the need to enter multiple versions 
of the same access rule for each network or VPN. Thus regions allow flexibility 

20 in tailoring a security policy. In defining regions, the first task is to group 

together networks or VPNs that require the same type of network access. Each 
network interface card or VPN that is grouped in a region is considered a 
member of that region. A region can consist of the following members: 

• an interface card, 
25 • a VPN, 

• a group of VPNs, 

• an interface card and a VPN, or 

• an interface card and a group of VPNs. 

Hence in Figure 2, userl, user2, user3, mgrl, and mgr2 of Region 
30 named R&D Network would have the same rights defined for the R&D Region. 
In the same way, Roaming Sales 1, Roaming Sales 2, Roaming Sales 3, etc. 
would have the same rights accorded to all members of Region named Sales 
Offices. In Figure 2, userl, user2, Roaming Sales 1, Roaming Sales 2, mgrl, 
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etc., do not necessarily represent only workstations. In other words, it is possible 
for user2 to logon the workstation onto which user3 might ordinarily logon, or 
for mgrl to logon the workstation onto which mgr3 might ordinarily logon. 

Every region is protected from every other region as defined in 
5 the firewall of the present invention. All connections to and from each region 
are first examined by the firewall. Regions may communicate with each other 
only if an appropriate access rule has been defined. For each access rule, first, 
the services that the rule will control must be defined, then, second, the regions 
that the connection is traveling between must also be defined. For example, if 

10 the Internal region is to be allowed to access Telnet services on the Internet 
region, the access rule must specify Telnet as the service that the rule controls 
and specify the From: region as Internal and the To: region as Internet. Hence, 
the firewall of the present invention does not allow traffic to pass directly 
through the firewall in any direction. Region to Region connections are made 

15 via an application aware gateway. Application-level gateways understand and 
interpret network protocol and provide increased access control ability. 

The ACLs are the heart and soul of the firewall. For each 
connection attempt, the firewall checks the ACLs for permissions on use and for 
constraints for the connection. Constraints can include: encryption requirements, 

20 authentication requirements, time of day restrictions, concurrent sessions 
restrictions, connection redirection, address or host name restrictions, user 
restrictions and so forth. 

Access rules are the way in which the firewall protects regions 
from unauthorized access. For each connection attempt, the firewall checks it 

25 against the defined access rules. The rule that matches the characteristics of the 
connection request is used to determine whether the connection should be 
allowed or denied. 

With the firewall of the present invention, access rules are created 
in a completely new way - using decision trees. Knowing that an access rule is 

30 based on a series of decisions made about a connection, the firewall permits the 
building of an access rule based on "nodes" of decision criteria. A node can be 
added to check for such criteria as the time of day, whether the connection uses 
the appropriate authentication or encryption, the user or groups initiating the 
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connection request or the IP address or host of the connection. Each node is 
compared against an incoming connection request and you determine whether 
the connection is allowed or denied based on the results of the node comparison. 

Every access rule must consist of two specific nodes. The first, 
5 the Services node, decides which service(s) the rule will control. The second, the 
From/To node determines the source region and destination region of the 
connection. Once the services and regions for the rule are established, more 
nodes can be added to determine specific details about the connection. 

This approach provides a new way to control network access. The 

10 Firewall presents access rules as visual decision tree diagrams. Each diagram 
contains building blocks or nodes of information that apply a condition . to or 
make a decision about the connection. At any point, you can add alerts to 
indicate when a particular point in an access rule has been reached or filters to 
check for authentication, encryption, WWW blocking or FTP commands. 

15 In addition to the Allow or Deny terminal nodes, there are four 

other types of nodes you can add to an access rule: decision nodes, filter nodes, 
redirects and alerts. Decision nodes will be discussed next. 

At any point in an access rule, you can check a connection request 
based on the time of day, its users and groups, its IP addresses and hosts or 

20 maximum concurrent sessions At these decision nodes, the Firewall determines 
whether the connection is true or false. If the connection meets the criteria listed 
in the node, the connection is considered true and proceeds along a "true" 
branch. If the connection does not meet the node criteria, the connection is 
considered false and proceeds along a "false" branch. 

25 You can apply a filter at any point in an access rule. Filters differ 

from decision nodes in that they do not determine if a connection is true or false. 
Instead, filters attempt to apply a condition to the connection. If the filter can be 
applied to the connection, the filter is performed and the connection proceeds 
along the same path. If the filter does not apply to the connection, the filter is 

30 ignored and the connection still proceeds. In one embodiment, the filter node 
can force user authentication or encryption, can use filters to block particular 
WWW connections, or can filter the connection to see if it contains Java or 
ActiveX content. 



WO 99^48261 PCT/US99/05991 

10 

A rewrite node is a point in an access rule where source or 
destination addresses are mapped to other source or destination addresses. 
Destination IP address rewrites allow an inbound connection through NAT 
address hiding to be remapped to a destination inside the NAT barrier. Source 
5 address rewrites can be used on outbound connections to make the source appear 
to be one of many external addresses. This process allows the internal hosts to be 
aliased to external addresses. In one embodiment, rewrites can be based on any 
connection criteria, including users. 

At any point in an access rule, you can add an alert that notifies 

10 recipients when a connection has reached a particular point in an access rule. 

Using these alerts, you can monitor specific users, IP addresses and other criteria 
contained within a specific access rule. 

When a connection request reaches a node in a rule, it is checked 
against the information in the node. If the connection is a filter node 72, the filter 

15 condition is either applied or ignored. Only one branch leads out of a filter node. 
If the node happens to be a decision node, there are two possible results. If the 
connection meets the criteria listed, it is considered true and follows the "true" 
branch of the access rule. Otherwise, the connection is considered "false" and 
follows the false branch. 

20 Referring to Figure 3, the design for this feature falls almost 

directly out of the GUI representation. The GUI presents access rules as a 
decision tree with special kinds of nodes which make true or false decisions. 
Each decision leads to a branch which contains more nodes. Along the way, 
filters can be acquired. These filters are not processed by the kernel with the 

25 exception of redirects (rewrite destination address or port). In Figure 3, the time 
of day is checked (50). If during business hours, the user is checked (52). 
Certain users are allowed, so connection is allowed (54) as indicated by the 
check mark. However, some users (56) require a SmartFilter check (58), where- 
as everyone else is denied (60). 

30 The firewall of the present invention introduces a revolutionary 

means to manage network access control. Traditional firewalls provide lists of 
access control rules, but as more rules and controls are added, these lists become 
unmanageable. As shown in Figure 3, the present invention presents a visual 
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means by which access control can be defined and easily understood through 
flowchart style diagrams. 

The firewall's access flow diagrams allow any decision criteria to 
be based on any other decision, in any order. If the administrator wants to check 
5 user first, then time, then apply a specific access policy, they can. In addition, 
the flow diagrams are object oriented for greater power. 

Access control rules on the firewall can be defined with flexibility 
previously unknown in the industry. This allows, for example, for different web 
filtering polices on a per-user basis, the ability to deny a connection if it isn't 
10 encrypted, authenticate a connection by strong token and another connection by 
password. Access rules can incorporate any of the following criteria: 



Protocol filters (WWW, FTP - see later in this section) 
SraartFilter™ URL blocking policy (see later in this section) 
Multiple external IP address connected to 
Source and destination service port and IP address rewrites 

The firewall's access control diagrams include the capability of IP 



address rewrites, which allows a connection inbound through NAT address 
hiding to be remapped to a destination inside the NAT barrier. Also, rewrites 
can be used on outbound connections to make the source appear to be one of 
many external addresses. This allows internal hosts to be aliased to external 
addresses. 

Rewrites can be based on any connection criteria, including users. 
So the administrator can have anonymous FTP connections directed to a public 



20 



15 



Source and destination Region 
Users and groups 

Source and destination addresses, networks, hosts, and domains 
Type of service (WWW, Email, Telnet, FTP, etc.) 
Time of day, Day of week 
Load balancing 

Maximum number of concurrent sessions 
Required level of encryption 

Required level of authentication (strong token, password, etc.) 
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access FTP server on the Secure Server Net, but remap users to their internal 
machines. 

The firewall's access control diagrams also include the capability 
of sending alerts, with an administrator-defined message, based on any 

5 connection decision. Alerts can be dropped into the access flow diagrams at any 
point. If a connection reaches that point in the diagram, the alert is triggered. 
For example, in Figure 4, a check for viruses is performed on a file (70). If a 
virus is found, the administrator is alerted (72), and the transfer is redirected to a 
safe location for later inspection (74). 

0 The ACLs consist of all the required kernel code. This is all the 

code that implements the rules themselves in the kernel including: build, 
modifying, deleting, and querying the rules. Also included arc the system calls 
that the user level programs need to use the ACLs. The parsing of the return 
values, especially the filters are not part of the ACLs themselves since the filter 

S rules are defined dynamically by the programs issuing the system calls to build 
the ACLs. It is the intent that the kernel be flexible enough to handle all the 
filter requirements without needing modifications for future enhancements. 

The ACLs themselves must satisfy the requirements laid out by 
the GUI design. This dictates to a large degree how the rules must be 

} implemented. Since the user has no direct access to the ACLs (rather they use 
the user interface), there are no ease of use concerns here except to say that the 
ACLs must be something the developers can work with easily. Hence, there 
exists a good set of tools to debug the ACLs. 

Virtual Private Networking (VPN) has been embedded into the 

5 architecture of the firewall of the present invention, making it an operating 
characteristic of the operating system, as opposed to other firewalls which added 
VPN later. Every access control is available to VPN connections in exactly the 
same way as for physically connected networks: user controls, IP restrictions, 
protocol filters, address hiding, multi-homing, and more. VPN is a method of 

) authenticating and transparently encrypting bi-directional data transmissions via 
the Internet. Both gateway to gateway network links as well as roaming users on 
VPN enabled laptops are utilizing the security and cost effectiveness of VPN 
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Internet encrypted communications. VPN technology is embedded in the core 
design of the firewall of the present invention. 

There are usually 2 sockets per session, client_sock and 
server_sock. Each socket has two endpoints, so there can be up to four different 
5 IP addresses. Note that ioc_dst_addr could be anything, if the firewall bound to 
a wildcard address. Here are diagrams for BFS Inbound, BFS Outbound, and the 
firewall of the present invention. 

client_sock server_sock 

10 client (cli_addr) > [firewall (invention) ] > (srv_addr) 

server 

(loc_dst_addr) (loc_src_addr) 



The SIGWINCH signal is used to force all ACLs to be rechecked 
15 and for proxies to re-initialize themselves (for proxies that use config files). 
Most proxies wiMiandle this signal themselves, but if secured did an ACL 
before starting a proxy, it must also do the recheck. The SIGWINCH signal will 
come from the backend, which will use killpg() to signal all the inetd daemons, 
secured processes, and their child proxies or servers. Note that the default action 
20 for SIGWINCH is ignore, so inetd did not need to be modified. 

Some transient proxies use the SIGALRM internally to do idle 
proxy timeouts (tcpgsp, tnauthp, sqlp). 

All proxies should shutdown cleanly if given a SIGTERM signal. 
The backend (daemond actually) uses SIGTERM to kill inetd processes when 
25 the last service has been removed. We have modified inetd to catch SIGTERM 
and then use killpg(SIGTERM, pgid) to kill all its children (proxies and 
secureds). When it starts up, inetd creates a new process group and becomes the 
leader, which allows it to kill all children easily. 

Squid will re-open (not rotate) its logfiles if given the SIGUSR1 
30 signal, and re-initialize itself if given SIGWINCH or SIGHUP. Note that this 
means squid does not do ACL rechecks, it treats it just like a SIGHUP - closes 
its listen sockets and waits 30 seconds for active sessions to terminate, then 
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re-opens listen sockets. This easy way out was chosen because squid's 
connections are relatively short-lived. 

The following options are passed to secured by the backend 
writing them on the inetd.conf line: 
5 -D te_dom Set the TE domain of our child process to te_dom 

-N service_number the service number is required for ACL calls. 

secured will pass this number on to all proxies 

10 -t Specifies that secured is running a transient service (with 

the wait flag in inetd.conf). ACL checks are not done by 
secured for transient services, because the service itself 
must do ACL checks. 

15 -u Specifies that this service supports the notion of a user 

name, so secured should let service perform its own ACL 
checks. Currently only FTP, telnet and WWW support 
user names. Note: only needed for ftpp, because tnauthp 
and squid already do their own ACLs. 

20 

The following options are passed to a proxy by the backend writing them on the 
inetd.conf line: 



-a audit_name use 'name* in call to openlogO and for auditing 

25 -i N specify session idle timeout as N seconds 

-I N specify proxy idle timeout as N seconds (transient only) 

-p ch specify descriptor port, ch=S for secure, ch=L for lpr, 

30 ch=<3 for generic, otherwise, ch=N specify fixed port, or 

ch^low-high to specify a port range 



The following ACL return values are passed to short-lived proxies by secured: 
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-N service_number the same service number that secured got via backend 

-c cli _rgn set cIi_region 

5 -s srv_rgn set srvjregion 

-D IP specify the server IP address 

-M IP specify an IP address to spoof as loc_src_addr, for 
10 MAT-out 

-p N specify the server port number 

-P N specify fixed value for descriptor port 

15 

-C spoof client-side socket (typically outbound proxies) 

-S spoof server-side socket (typically inbound proxies) 

20 By letting the ACLs control so many settings, the inetd.conf lines 



are much simpler and the degree of control is much greater. For example, here 
are some BFS inetd.conf entries for inbound proxies: 

inbound_udp_j-elay -e 199.71.190.101 -w 65546 -u g_udp_ir -d 192.168.128.138 -m -g 0 
secured -ws 144 -wr 1 -wn 1 -1 199.71.190.121 www_X wwjr_i - - -d 192.168.125.2 -m 

25 

Here are the corresponding entries for the firewall of the present invention: 
secured -N 123 -D RGnx -t - ntpp -a ntpp 
secured -N 456 -D RGnx -t - httpp -a httpp 



30 



The following options are only used for debugging purposes, 
some might be disabled on production systems or supported in future releases: 
-n non-transparent proxy mode - only works for VDO-Live 
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-U user name set the user name (ftp ftpjnux and ftpp/ftpd) 



-A ch set the audit method, ch=s for syslog, ch=a for audit, ch=e 

for stderr 

5 

-m disable socket mating 



-L disable connection logging 

10 -z set non-paranoid mode, which relaxes IP address checks 

for UDP proxies 



The firewall of the present invention uses new structured audit 
calls for session logging, which include src and dst region, ACL matched, auth 
15 method, encryption state, etc. The new calls are: 

• au&it^session^begin 

• auditsessioncontinue 

• audit_session_end 

20 • audit_log_ftp - to log FTP file transfers, includes user, filename, 



size 



audit_log_smartfilter - to log URL, action (allow/deny), blocked 



categories 



audit_acl_deny - to log ACL denials 
25 • audit_jpsec_fail - to log IPSEC failures 

audit auth fail - to log authentication failures 



The present firewall has incorporated the proxy-warder-interface 
(pwif) from Sidewinder. We also support external authentication servers such as 
30 snk, safeword, securid The pwif interface was already supported by tnauthp, we 
added pwif support to ftpp, and for GUI login. We are not using pwif for squid, 
instead we are using their build-in passwd file support. The backend will have to 
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keep the squid passwd file in sync with the static-passwd file used for ftp and 
telnet. 

Besides a simple allow/deny, the ACLs also return the following: 
from_region, to_region, destination redirects for EP and port, source redirects for 
5 IP and port, transparency settings and filters. We have standardized ACL filters 
as follows (example from aclutil.h): 
#defme FILT_DELIM T 
/* 

* all filters will be at least 3 -characters in length 
10 * proxy ACL filters will all start with "p" 

* all filters should be disabled (0) by unless ACLs enable them 
*/ 

/* generic proxy filters - all start with "pg" 

15 * filt_debug filter "pgdN" sets debug level to N 

* •* 

* filt_crypto_from filter M pgeR:levels" requires encryption in regions R, 

* filt_crypto_to where R equals F, T, B for from_rgn, to_rgn T both, 

* filt_crypto Jevels and levels is colon delimited in 
20 "rc4-40:rc4-128:des56:3des" 

* For example, pgeF:rc4-128:3des" would force strong 

* encryption between the client and the firewall 
* 

* filt Joc_auth filter "pgaX" specifies local auth 

25 * the character X gives the method: S, s, w 

* for STRONG_ONLY, STRONG_PREFER, 
WEAKJPREFER 

* fiK_rem_auth TRUE or FALSE 

30 * filt_undef_servers filter M pgA:" specifies list of remote auth methods, 

* colon delimited ,, pgA:radius:safeword:securid:snk M 
*/ 



WO 99/48261 



PCT/US99/05991 



18 

typedef struct { 

/* generic proxy filters - see above for their defined values */ 

char filt_debug; 

char filt_crypto_from; 

char filt_crypto_to; 

int filt_crypto_levels; 

char filt_loc_auth; 

char filt_rem_auth; 

char**filt undef servers; 



10 



/* FTP proxy filters - all start with "pf ' 



■7 



char filt_port; 

char filt_pasv; 

char filt_get; 
15 char filt_put; 

char filt_site; 

char filt_mkdir; 

char filt_jmdir; 

char filt_delete; 
20 char filt_rename; 

commands*/ 

char filt_anon; 
anonymous */ 

ujong £ilt_size; 
25 } ftp_acl_filter_t; 



/* filter "pfo" disables PORT command */ 
/* filter "pfa" disables PAS V command */ 
/* filter "pfg" disables RETR command */ 
/* filter "pfp" disables STOR command */ 
/* filter "pfs" disables SITE command V 
/* filter "pfm" disables MKD command */ 
/* filter "pAr" disables RMD command */ 
/* filter "pfd" disables DELE command */ 
I* filter "pfv" disables RNFR & RNTO 

/* filter "pfP disables USER ftp and 

/* filter n pfSN" sets N KB to max file size +1 



30 



Here are some example filter strings, from acMoad.c: 

/* FTP: site, del, WWW: java, activex, cookies */ 

#define FELTER_STR1 "pfs|pfd|pwj|pwa|pwcr r 
/* generic filter: debug=3 */ 

#define FILTER_STR2 "pgd3|" 

7* debug=2, FTP: 69K, strong auth, with external auth servers */ 

#define FILTER STR3 n pgd2|pfS69|pgaS|pgA:safewordOTdiusr' 
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S QW D I ssues 

The caching WWW proxy (squid) is very interesting because it 
has its own ACL checks and non-blocking DNS interface. We leveraged this 
built-in support in our work, but it was still tricky to integrate the firewall's ACL 
5 calls while operating as a non-blocking long-lived proxy. 

Squid supports something called proxy-authentication, but this 
will only work if someone has configured their web browser to contact a proxy 
for all URLs. Before doing ACL checks, we use the following code to handle 
this special case: 
10 if (scc_getregion(&conn-;>me.sin_addr) = 0) 

name_valid =1; /* no n- transparent mode supports proxy-auth */ 

else 

name_valid = 0; /* transparent mode does not */ 

15 This will cause ACL checks for transparent HTTP requests to 

bypass user nodes, and squid will ignore auth filters. Non-transparent requests 
(where the connection is TO the firewall) will enforce any user nodes and auth 
filters in the ACL tree. 

Since the proxy might not get an authentication filter after the 

20 ACLs return NEEDS JJSERNAME, the squid proxy-auth code has been 

changed to not return a failure code if the password was not accepted. Instead we 
save some internal state, and only check this state if an authentication filter is 
returned later. 

It is worth noting that in non-transparent mode squid can prbxy 
25 and authenticate http, gopher, ftp and wais URLs. 



In the Proxy 

The proxy will make two calls to the ACLs. The first will be: 
int scc_is_service_allowed( 
30 unsigned long servicejiumber, 

struct sockaddr_in *src_ip, 
struct sockaddrjn *dst_ip, 

char *srcJiost_name, /* usually null */ 
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char *dst_host_name ? 
char *user_name, 
int narne_valid, 
/* return values */ 
5 int &to_region; 

int &from_region; 
int &filter_text_len, 
char &filter_text, 
int nile_name_Jen, 
1 0 char &rule_name, 

struct sockaddrjn &redirect_src__addr _port, 
struct sockaddr_in &redirect_dst_addr_port, 
int &masterjkey, 

caddr_t &connection_id /* id for this connection */ 

15 ); 

The possible return values will be: 

#define ACL_DENY 0 

#define ACL_ALLOW_HIDE_SRC 1 
20 #define ACL_ALLO W_HH)E_D S T 2 

#define ACL_ALLOW_HTOE_BOTH 3 

#define ACL_ALLOW_SHOW_ALL 4 

#define ACL_RESOLVE_SRC_ADDR 5 

#define ACL_RESOLVE_DST_ADDR 6 
25 #define ACL_NEED_MORE_FILTER_SPACE 7 

#define ACL_NEED_USER_NAME 8 

Thus the ACLs will return, for each connection, how to hide the addresses. The 
description of each of these values is as follows: 
30 service_number: this is a number that the backend decides and is unique per 
service or possibly per service, from and to region triplet as desired. 

src_ip: this is the source IP address of the connection. 



/* usually null */ 
/* null if none */ 
/* tell if name is valid */ 
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dst_ip: this is the destination IP address of the connection. 



PCT/US99/05991 



src_host_name: this is the host name based on the reverse lookup of the source 
address of the connection. This is generally only used when the kernel explicitly 
5 asks for it by returning from a previous call to sccjisjservicejallowed with a 
return value of ACLJLESOLVE_SRC_ADDR. 

dst_host_name: this is the* host name based on the reverse lookup of the 
destination address of the connection. This is generally only used when the 
[) kernel explicitly asks for it by returning from a previous call to 

sccJs_servicej2llowed with a return value of A CL_RESOL VE_DST_ADDR . 

userjiame: this is the user name of the person using the service. This value is 
only used when ACL_NEEDJJSER_NAME has been returned by the kernel. 
5 Use NULL, if the name has not yet been requested. Currently only FTP, telnet 
and WWW suppqrt user names. 

name_valid: this tells the ACLs whether or not a user name makes any sense for 
this protocol. If the name_yalid flag is set to TRUE, then user decision nodes 
3 will be used (and thus a user name will be required if a user decision node is 
encountered when checking the ACL). If set to false, then the user decision 
nodes will be ignored and the true path of those nodes encountered when 
checking the ACL will be used. 

5 to_region: the region number that the destination address of this connection is in. 

from_region: the region number that the source address of this connection is in. 

filter_textjen: this is a pointer to an integer which has the length of the 
3 filter jext array in it. This value will be set to the amount of data returned by the 
access call on return. If the return value is 

A CL_NEEDJAORE_FIL TERJSPA CE y then the value in this variable will 
contain the amount of space required. 
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filterjext: this is an array of characters of size filter Jext Jen which will be used 
to store the concatenated filter strings accumulated while checking the ACLs. 

rule_name_len: this is the size of the array rulejiame. 

5 

rulejiame: this is the name of the rule that allowed or denied the connection. 
Only a maximum of ndejiamejen - 1 characters will be stored in there. 



redirect_dst_addr_port: this is the address and port to redirect this connection to. 
10 The system will set this to all zeroes if it is not in use. The port and address will 
always both be set together in this structure if it is to be used. Only the sin _j?ort 
and sinjiddr part of the structure will be used. 

redirect_src_addrj>ort: this is used to indicate to the firewall that when making 
15 the connection from the firewall to the destination, it should use the source 
address/port provided. Note that unlike the redirect jlstjiddr jport field only 
the parts of the address required will be filled out. In particular, if the port is 
specified but not the address then the address field will be zero. Similarly, if the 
address is specified but not the port, then the port will be zero. For the 
20 redirect jistjxddr _port, if one or both field are specified then they are both 
returned (with the unspecified field left the same as the actual destination). 

masterjcey: this is the key that indicates which items have been licensed on the 
firewall. 

25 

connection_id: this is the connection id for this connection. When the service is 
finished you provide this id to the sec ^service Jone system call and that 
function decrements the correct counters. 

30 Note that the user name will be used by the system to get the 

groups automatically behind the scenes in the library call. This means that the 
actual call to the kernel will have more fields. In particular, there will be a list of 
group names and a counter to indicate how many elements are in the list. 



WO 99/48261 



PCT/US99/05991 



23 

The second call will be: 

int scc_service_done(caddrj connection_id); 



This call always returns zero now. The kernel will use the 
5 information in the proc structure for this process to decrement the connection 
counts for this connection. 

There is one other call that a proxy might have to make. When an 
ACL is updated, proxies have to recheck their connections to see if they can still 
make the connection. This is done as follows: 
10 int scc_recheck_service( 

unsigned long service_number, 
struct.sockaddrjn *src_jp, 
struct sockaddrjn *dst_ip, 
char *src_host_name, 
15 char *dst_host_name, 

char *userjtiame t 
int name_valid, 
caddr_t &connection_id 
/* return values */ 
20 int &to_region; 

int &from_region; 
int &filterj:extjen, 
char &fllter_text, 
int rule_name_len, 
25 char &rule_name, 

struct sockaddr^in &redirect_src_addr_port, 
struct sockaddrin &redirect_dst_addr_port, 
int &master_key 

); 

30 Returns from this will be the same as for the 

sccJs_servicejzllowed call except that connection Jd is passed in as a 
parameter not a return value. 



/* usually null */ 

/* usually null */ 

/* null if none */ 

/* tell if name is valid */ 

/* id for this connection */ 
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If the connection is not allowed, then the counters are 
automatically freed up and the proxy need not make any further calls for that 
connection. In the case of counter nodes, the recheck will fail until the counter is 
at an acceptable level. This means that, if the counter has been decreased below 
5 current connection levels, the first connection rechecked will fail and so on until 
the current number of connections counter has been decremented enough. Thus, 
proxies should recheck services in order of lowest priority to highest priority 
(typically by checking the oldest sessions first, when that is possible). Note that 
short-lived proxies and servers started by secured cannot guarantee the order in 
1 0 which ACLs will be rechecked, since they will all get a HUP signal at the same 
time. 

The following new system calls were added to BSDI 3.1 version 
of UNIX to support regions: 

rgnbindO allows a service on the firewall to listen for network 

connections only in the specified region. This allows us 
A to have different programs listening in different regions; 
for example, a caching WWW proxy for connections from 
internal to external and a non-caching proxy from SSN to 
external. In one embodiment, network servers were 
modified to use rgnbindO instead of bind(), to ensure that 
they handled traffic for the correct region. 
15 rgnctlO adds, deletes, and modifies regions and sets per-region 

parameters: Members, router, connection refused, and 
ping response, 

rrctl() sets region-to-region policy. Currently only handles 

network address translation, but could add other 
parameters in future. 

scc_getregion() retrieve the region number for a given IP address 

scc_service_checks() 

scc_backend_acl_calls() 
20 scc_service_done() 

scc_get_service_counts() 
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Other changes include: 

initialization of region table at system startup time; 

• addition of a region number to the packet header data structure to 
5 record the region ED for every network packet received; 

• addition of a field to the network interface data to record which 
region that interface belongs to; and 

addition of a field to the VPN security association data to record 
which region the VPN is belongs to. 
10 • In the ICMP (Internet Control Message Protocol) processing, if 

the incoming packet is an ICMP ECHOJRJEQUEST (commonly known as a 
"ping"), check the region table and only respond if ping response is enabled for 
the region from which the packet came; 

In the EPSec key and policy processing code, code was added to 
15 record the region ED associated with keys and policy table entries, and to 
manipulate keys aJ&d policies on a region-by-region basis; 

• List of changed files: Region modifications were made to the 
following files within the BSD/OS kernel: 



kem/uipcjiibuf.c 


netpolicy/pWiebug.c 


kem/uipc_syscalls.c 


netpolicy/ptsock.c 


ACL/acIservicex 


netpolicy/policy.c 


netinet/ip_input.c 


netsec/ipsec.c 


netinet/in_pcb.c 


netsec/ipsec_ah.c 


netinet/in_pcb.h 


netsec/ipsec_esp.c 


netinet/ip_icmp.c 


sys/aclkem.h 


netinet/ip_tunnel.c 


sys/audit_codes.h 


netinet/raw_ip.c 


sys/mbufh 


netinet/tcp input.c 


sys/region.h 


netinet/udp_usrreq.c 


sys/sysctl.h 


netkey/key.c 


net/if.c 


netpolicy/policy.h 


net/i£h 
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Region Determination Processing 

Referring to Figure 5, when a packet is received as shown in step 
80, the region ID is retrieved from the network interface and assigned to the 

5 packet in step 82. It is determined in step 84 whether the packet is encrypted, 
i.e., a VPN. If the packet is encrypted, processing proceeds to step 86 where the 
VPN security association for that packet is retrieved. The packet is then 
decrypted in step 88, and the previously stored region ID for that packet is 
replaced with the region ID of the VPN in step 90. All further operations take 

1 0 place on the decrypted packet. 

Ordinarily, a UNIX system then checks whether the packet is 
destined for one of the firewall's IP addresses. If not, the packet is forwarded to 
the real destination. This has been modified in SecureOS to check that: (a) the 
destination is in the same region as the source and (b) the "router" flag is set for 

15 that region, as shown in steps 92 and 94. If either condition is not met, the 
packet is not forwarded, as shown in step 102. 

In step 96, the system looks for any socket listening for the 
incoming packet. Traditionally this match looks at source IP address, source IP 
port, destination address, and destination port. This has been extended in 

20 SecureOS, as shown in step 98, to also check the region associated with the m 
packet against the region specified in the rgnbind() system call, to ensure that 
sockets receive data originating only from the correct region. If all conditions 
are met, the packet is forwarded in step 100; otherwise, the packet is not 
forwarded (step 102). 

25 This folowing example sets up three regions: internal, external, 

and Secure Server Net (SSN): 
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Name 


Members 


We show 
address to 


We see 
address from 


Rtr 


Conn 


Ping 


Internal 


efD Ethernet 




External 


1 


1 


1 




VPN- 
Waterloo 




SSN 








External 


efl Ethernet 


Internal 
SSN 




0 


0 


0 


SSN 


ef2 Ethernet 


Internal 


External 


1 


1 


1 



5 

The fields are: 



Name 


user specified region name 


Members 


physical interfaces and VPN encrypted connections that 
belong to this region. 


We Show AddrTo 
We See Addr From 


the Network Address Translation configuration. This 
example shows that the Internal region is hidden from 
all others, and that the SSN region is hidden from 
External but visible to Internal 


Rtr 


if 1, the firewall acts as a router between members of 
this region. In this example, packets would flow 
between the Internal region and the VPN to Waterloo 
as if they were simply going through a router. 


Conn 


If 1, the firewall returns "connection refused" messages 
if there is no service available on the requested network 
port. Setting this to 0 on external regions can help 
defeat network scanning attacks. 


Ping 


Respond to network pings (ICMP ECHO-REQUEST 
packets). Again, setting to 0 on external regions can 
help defeat network scans. 



15 



The following example shows a region of the firewall of the present invention 
configured to sit between two departments of a company and transparently filter 
and control network access between the departments. 
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Name 


Members 


We show 


We see 


Rtr 


Conn 


Ping 






address to 


address from 








Service 


efO Ethernet 


Research 


Research 


i 


1 


1 


Research 


efl Ethernet 


Service 


Service 


1 


1 


1 



5 The two regions can see each others' IP addresses; that is, no address translation 
is done. Nevertheless, network connections arc only allowed if an access rule on 
the firewall grants permission. 

The ACLs described above combine the services themselves, the regions 
that the services bridge, and the access control decisions. The user draws a graph 

10 which starts with a service and a to-from set. Next, the user creates a path 
consisting of the desired options which can include: time, session counts, 
authentication, encryption, users/groups, WWW filters, ftp filters, email filters, 
destination address re-writes, to addresses and from addresses. The user is 
building a decision tree. 

15 In the embodiment shown, some of the decision nodes in the tree have 

two paths from them to the next node (a true path and a false path) and some just 
have one path. The nodes that have one path are nodes which provide filtering, 
logging, or address rewrites. No decisions are made on filtering since filtering is 
performed in user level code. (For example, to make the implementation easier, 

20 the kernel will not try to implement SmartFilter. Instead, the result of the ACL 
check will be to provide a response which notes SmartFilter should be applied 
and supplies the categories which are to be blocked. The proxy will allow the 
connection provided that the SmartFilter check allows the connection.) 

As noted above, in one embodiment each node in the decision tree can be 

25 one of two types of node. The first type is a decision node. The second type of 
node is a filtemode. 

A decision node is one where the decision regarding the action to 
perform is done in the kernel. To the user, on the GUI, it means that they can 
have a true branch and a false branch. This node is implemented in user space 

30 in the service itself. 
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A filter node is implemented in user space in the service itself. The 
service will ignore filters which do not apply to it. To the user, on the GUI, it 
means that they can only have a true branch. The false branch is always a deny 
service. 

5 

Decision Nodes 

This section describes one embodiment of the decision nodes and their 
associated data structures. Also described are the system calls that will be 
available to work on the node. This design assumes that each ACL will consist 
10 of first a list of services, followed by some to/from region decisions, and then 
followed by anything else desired. 

The scc_decisionjiode is a union structure that looks like this: 



struct scc_ decision_node { 
15 char *node_descriptor ; 

loop_check; 

scc_decision_node *true_j?ath; 
s cc__deci s i on^node * f a 1 s e_jpa t h ; 
int ref erence_count ; 
20 int node_has_been_deleted; 

int node_type ; 
int debug__node; 
union { 

scc_user_rec user_struct; 
25 s c c__a ddr_r e c addr_s t r uc t ; 

scc_counter_rec counter_struct ; 

scc_decision_node *subrule_ptr ; 

scc_date_rec date_struct; 

scc_f ilter_rec f ilter_struct ; 
30 scc_log_rec log__struct; 

scc_rewrite_rec rewrite_struct ; 

scc_mat_rec mat_struct; 
} detail_data; 

} 

35 

nodejype is one of: 



tfdefine ACL_SERVICE_DECISION_NODE 0 
tfdefine ACL_USER_DECISION_NODE 1 
40 #define ACL_ADDR_DEC I S I ON_NODE 2 

#define ACL_COUNTER_DECISION_NODE 3 
#define ACL_RULE_DECISION_NODE 4 
#def ine ACL DATE DECISION NODE 5 
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#define ACL_FILTER_NODE 6 
#define ACL_L0G_NODE 7 
#define ACL_REDIRECT_NODE 8 
#define ACL_PERMIT_SERVICE 9 
5 tfdefine ACL_DENY_SERVICE 10 

which describes which of the union pointers to use. And, in the case of the end of 
the path, the nodejype indicates if a permit or deny is to be used. 

Note that the subrule _ptr is to implement the rule within a rule 
10 requirement of the GUI. 

If a decision to check is true, then the true j>ath is the next node to 
check. Similarly for a false decision. 

The nodejdescriptor is a character string which describes this particular 
node. There is no set definition for this description so the backend is free to 
15 enumerate nodes as it wishes and the GUL^ackend can use node descriptors to 
glue together messages from the audit stream to trace through what is happening 
in the decision process. Also we use the node descriptor as an index into a the 
node table. This table has as entries a pointer to each node for fast node lookup. 

If a node is deleted, then the nodejiasjbeenjleleted flag is set. If at any 
20 point in a ACL check we come across such a node we issue a deny. We use the 
reference jcount to determine if we actually delete the node. Only when the 
reference count is zero do we actually free up the memory. 

The debug jxode flag can be set to do various things as will be discussed 

below. 

25 We use the loop_check flag to prevent loops in the ACLs causing us to 

recurse forever. We set this flag to true when we enter this node for checking and 
after checking the children to the end we reset the value to false. If while 
checking the children we encounter a loop flag set to true we know we have 
reached cycle in the tree. 

30 The Services node and regions node are special decision node which 

anchor the decision tree. This allows for quick indexing by service number. To 
do this, there will be an array of pointers ( scc_servicejxrray) indexed by the 
service number. The pointers point to and array of regions used by that service. 
There will be a variable max ^service jxumber which the kernel will maintain to 
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10 



use as a guild line for indexing into the service array. Each entry in the 
sccjservice_array will be a structure as follows: 



struct scc_service_def { 
int numberjregions; 
scc_service_rec **region_array ; 
int ref erence_count ; 
int node_has_been_de 1 e t ed ; 

} 



Each service should have a unique number but this will not be 
implemented in the kernel. Rather, the kernel will be given a service number and 
the kernel will allocate a bucket for that service. The kernel will be unconcerned 
about which service this bucket actually belongs to. Note that the 

1 5 scc_service_rec is not a part of the sccjiecisionjtode listed above. 

When we want to delete everything for an entire service (a user defined 
service for example), we check to see if all structures pointed at by the region 
array are empty. If not we mark this node as being deleted. The scc_service_recs 
pointed at by the region array will decrement the reference count as they get 

20 deleted (and freed) and when the reference count is zero this record is freed. 



struct scc_service_rec { 

int numberjregions; 

unsigned long total_sessions ; 
25 unsigned long current_sessions; 

scc_ decisionjriode *next_decision; 

char *node_descriptor; 

scc_service_def *parent_struct ; 

int to_region; 
30 int f rom_region; 

int debug_node; 

int node_hasJbeen_deleted; 

} 



35 When an ACL check is requested we use the service number to index into 

the table of services. This leads us to a sccjservicedef structure. We index into 
the region jzrray using the to and from regions. If the entry has a value (i.e. the 
pointer is not NULL) and if the nodejiasjbeenjdeleted flag is false, then this 



WO 99/48261 PCT/US99/05991 

32 

node is the start of a valid decision check. In this case, we use the 
sccjlecisionjiode pointer to start traversing this tree. If no decision tree is 
found for this particular region-service combination, then the service is denied 
access. 

5 We will keep track of sessions for each service-region combination so 

that other programs can check to see the status of traffic on the box. Thus, every 
time a success is returned, the counts here are increased and every time service 
de-registers, the proper counter, current ^sessions, is decreased. The 
nodejiasjbeenjieleted is there for when the service record is to be deleted. In 
10 this case, processes will continue to decrement the current jsessions until all the 
counts are zero. At that time, the memory will be freed. When we can free this 
structure we go back to the parent structure and NULL the entry in its 
region jirray. If all entries are null then free that structure if it is marked for 
deletion. 

15 The user decision node is used to make decisions specific to users or 

groups of users. Tjiis structure is simple and goes like this: 



struct scc_user_rec { 

char **sorted_user_array; 
20 int number_of_users; 

} 



If the user being checked is in the array of users, then the decision is 
true. If one of the groups that the user belongs to (also included in the system 
25 call) is in the array of users, then the decision is true. Note that users and groups 
are one and the same as far as the system goes. This means the GUI/backend 
must make sure that there is not a group called Andrew and a user called 
Andrew. 

If no user name was provided for the ACL check and if user names are 
30 relevant to this protocol (i.e. the namejvalid flag was set to true in the ACL 
call), then if the calling process does not provide a user name, 

#define ACL NEED USER_NAME 8 
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will be returned. The proxy would need to query for a user name and call again 
with that information. 

The IP Addresses/Host Names decision node is used to make decisions 
that select for/against source or destination addresses or host names. 

5 

struct scc_addr_rec { 
int type; 

char **sorted_hostname_array; 
int number_of_names ; 
10 radix tree of host numbers /network masks 

} 

Where type is either: 

15 #define ACL_ADDR_SRC_CHECK 0 
#define ACL_ADDR_DST_CHECK 1 

The same sfructure is used for a source address check and a destination 
address check. Note that if the address/mask set does not contain the current 
20 address being examined and if sorted Jiostnamejzrr ay contains some data, then 
if the correct name was not provided in the ACL call to the kernel, the kernel 
will return the value: 

#define ACL_RESOLVE_SRC_ADDR 2 
25 #define ACL_RESOLVE_DST_ADDR 3 

indicating which address needs to be resolved via a reverse DNS lookup. The 
ACL would then be called again with the resolved name. 

Note that the list of host names must be in sorted order but the letters of 

30 the hostname must be reversed. For example, rafaeLtor.securecomputing.com 
would be mocgnitupmoceruces.roUeafar. These are then put into sorted order. 
This allows the kernel to quickly process wild card entries. It is also important 
that unneeded entries are not loaded into the kernel. For example if the user has 
specified * com, then no other entries of the form .com should be present in the 

35 list passed to the kernel. 



WO 99/48261 



PCIYUS99/05991 



34 

The Maximum Concurrent Sessions decision node provides the ability to 
put a choke on the number of concurrent sessions on a service or group of 
services. We want to have the ability to program a counter to be shared among 
all the services on this path, or to have the counter count for each service 
5 individually. 

The structure to handle this looks like this: 



struct scc_count_rec { 

int service_specif ic__f lag; 
10 unsigned long cur rent_count ; 

unsigned long max_count; 

unsigned long total_count; 

scc_detail_count_rec **service_counters ,* 

unsigned long num_services; 
15 } 

Where the service ^specific Jlag can have values: 

#define ACL Js HARE_COUNT 0 
20 #define ACL_INDIVID_COUNT 1 

and if the servicejspecific Jlag has value A CLJSHAREjCO UNT, then the 
shared count record is used. Otherwise, the array is used. Note the size of the 
array is stored in numjservices and the array is indexed as: 

25 

service counters [service number] . 



The scc_detailjcountjrec is: 

30 struct scc_detail_count_rec { 

int numberjregions ; 

unsigned long service__number; 

unsigned long *current — count ; 

unsigned long *total_count ; 
35 scc_decision_node *parent_record; 

int node_has_been__deleted; 

} 
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where the current count tells how many connections that use this counter arc 
currently active. The total count is the total number of connections that have 
used this counter. We use the max j:ount from the scc_count_rec to determine 
the max. Thus the max is a shared value that all individual counts must adhere 
5 to. The arrays in the sccjdetailjcountj-ec are indexed as: 

current_count[to j-egion] [from_region] . 

Each time a detailed record is allocated the parent decision node's 
10 reference count is incremented. 

The nodeJtas_beenjieleted tells a process that is going to decrement 
the counter whether this node is being used or not. If set to false, then the record 
is in use and increments or decrements are done accordingly. If set to true, then 
when the count gets decremented to zero, the memory is freed up and the parent's 
15 reference counter is decremented. If the parent has been deleted and if the 
reference counter is set to zero then the parent node is freed. 

The nodehasjbeenjdeleted flag, in the detailed record, gets set to true 
(i.e. not zero) when the node itself goes away (the user has removed it from the 
diagram) or if the counter is switched from individual to shared service counts. 
20 Note that each counter is indexed by to region and from region so that the count 
is unique on a service-from region-to region triplet. 

The parent _record pointer points back to the top level 
sccjiecisionjiode. The service jiumber is there so that we can index into the 
service ^counters array and set the array pointer to NULL when we are preparing 
25 to free up memory. 

When the counter is switched from individual to shared service, then the 
records in the array are all invalidated. The totals of the counts of the array are 
added up as the new total jcount for this node (in the parent record). In order to 
keep the counters correct, when we decrement a counter, check to see if the 
30 record has been deleted. If the record is marked as deleted and if the 

parent _record is set to shared, then decrement the shared counter as well. If the 
individual counter is now zero, free up the memory as above. 
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The Time/Date decision node provides the ability to use date and time as 
a means of restricting access to services. The structures look like this: 



struct scc_date_rec { 

unsigned long number_details ; 
scc_date_detail_rec *date_details ; 

} 

struct scc_date_detail_rec { 

unsigned long start_seconds; 
unsigned long end_seconds; 

} 



The sccjdate_rec is the top level structure and it has number ^details 
separate date rules. Each of those rules are in a scc_date_detail_rec. So, we 
have an array of structures in sccjlate_rec each of which has a start seconds 
and an end seconds value. Each value is relative to the beginning of Sunday. 
Thus, start second 0 and end second 1 would be allowing the connection only 
during the first second of Sunday. 

The backend must provide the records in sorted order by start second. 

A time and date decision is based on a series of time rules. We simply 
check the current time and day against each rule. If we find a rule where the 
current time and day falls in that rule, then the decision is the true path otherwise 
it is the false path. 

In one embodiment, to be a complete rule, a rule must consist of at least a 
services node and a region node and have all true and false branches terminated 
by terminal nodes. If you plan to use a segment of a particular rule in more than 
one rule, you can create a partial rule. Partial, or shared, rules can be added to 
any complete rule. 

In one embodiment, complete or partial access rules can be configured 
using a graphical user interface such as is shown in Fig. 3. In order to configure 
a complete or partial rule one must perform the following general steps: 

1) decide if you want to create a complete or partial rule. 

2) select the services this rule will control. 

3) select the source region and destination region for the rule. 
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4) 
5) 



decide on a name for the rule. 



decide what nodes you want to add to this rule. 



10 



15 



20 



25 



30 



The ability to create shared rule segments is built into the system as 
fallows. A rule is simply a chain of decision nodes. After the chain of rules is 
completed, the decision path at the entry point to the sub-rule is taken based on 
the outcome of the rule. The filters and audit messages within the rule are still 
generated and accumulated. 

Log nodes direct the kernel to log messages to the audit subsystem. The 
backend can fully specify the message to log. The structure is as follows: 

struct scc_log_rec { 

char * audi t_mes sage; 
int audit_message_type; 



The message will be of the form: 

audit _printf (audit_message_type, 
AUD IT_A_AREA , 
AUD I T JT JNTETACL , 
AUDIT_P_MAJOR, 
"%s from ACL log node: %s", 
node_descriptor, 
audit_message) ; 

Note that an sccjogjiode always takes the true path of the decision tree. 

In one embodiment, filters are just strings which the proxy interprets to 
perform it's filtering. The kernel does none of the decision work. Instead, the 
kernel is given a pattern, and if the node is reached and if there is some data for 
the decision made at that node, then the pattern is accumulated as a filter. All of 
the filters are accumulated by the kernel, concatenated together and returned to 
the proxy as part of the system call In such an embodiment, the kernel requires 
no work to implement filters beyond the re-writing of addresses. 

A filter structure contains all the relevant filter data. The following shows 
the data and explains its use: 
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struct scc_f ilter_rec { 

char * f i 1 1 er_s t ring ; 

int f ilter_string_JLength; 

} 

5 

If the filterjstringjengih is zero, then there are no filters otherwise, this filter 
string is appended to the array passed in, in the ACL call by the service. 

The filters are as follows: encryption, authentication, 

The encryption filter requires that a connection is encrypted with a 
10 certain level of encryption. It will be up to the user level process to verify that 
the requirements of the filter are met. If the requirements are not met the action 
is to deny the connection. 

The authentication filter requires that a connection is authenticated. One 
or more possible methods of authentication can be specified. This would only 
1 5 apply to those protocols that allow for a user name as part of the protocol. 
Currently this would be: ftp, telnet, and WWW. 

There are a number of possible WWW Filters. For instance, SmartFilter 
can be used as described above. In addition, a WWW filter may block Java or 
ActiveX scripts. In one embodiment the SmartFilter filter can also specify which 
20 policy to use (for sites that define multiple policies). These are performed by the 
caching WWW proxy only. One such embodiment also includes cookie 
blocking. 

Likewise, there are a number of possible FTP Filters. These include 
filtering on: GET, PUT, PASV, PORT, MKDIR, RMDIR, RENAME, 
25 DELETE, SITE, filtering on file size and filtering anonymous ftp. All filtering 
must be done by the proxy or server. 

Furthermore, there are a number of email filters required. This includes 
mail mapping and content blocking. Again the proxy/server must fulfil the 
requirements of the filter. 

30 

Redirect nodes 

Redirect nodes act like filters since they only have one path out of them. 
Redirects are tables which map source or destination addresses to other source or 
destination addresses. Currently we only map destination addresses. The most 
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obvious use of redirects are to map connections coming into the firewall from 
the insecure side of a NAT region pair to a secure machine. In this case, the 
connecting host cannot see the hosts behind the firewall. The redirects will map a 
connection coming to a given firewall address (could be one of many because of 
5 MAT) to the desired secure host. The kernel will only accept addresses (the UI 
can accept names providing it translates them to an address). The tables, whose 
structure is described below, will contain an entry for each MAT address that 
applies. 

Another use of redirects is to map an address going from a region which 
1 0 can see all the hosts in the destination region. In this case, the redirect has only 
one entry which maps the address and port to the given address and port. 

The final case is one where we might not know which of the above two 
apply. In that case, all possible MAT addresses might be present and a global 
rule in the case that the connection is not to the Firewall itself, is also present. 
15 This final case happens when you are using a redirect from a rule within a rule. 
The structure for the redirect table is as follows: 



struct scc_rewrite_rec { 
int node_type ; 
int no_match_f lag ; 
int num_table__entries; 
scc_rewrite_rule *rewrite_rules ; 

} 

struct scc_rewrite_rule { 

struct sockaddr__in check_addr; /* including port 

*/ 

struct sockaddr_in netmask; /* netmask used 

for checking */ 

struct sockaddr_in new_addr; /* including port 

*/ 

} 

The nodejype is one of: 

ACL_SRC_REWRI TE JSTODE 
ACL DST REWRITE NODE 
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Since the number of addresses to check against are minimal, we will 
leave the addresses in unsorted order. 

The redirect mapping goes as follows: 

1. See if there is an address/port which matches the current 

5 connection. A port number of 0 means any port and an address of 0.0.0.0 means 
any address. 

2. If there is a matching address or port, to rewrite the addresses. 

3. If there is no match address then if the nojnatch Jlag is set to 
ACL_REWRITE_NO_MATCH__DENY then deny the connection. Otherwise 

10 leave the port and address unchanged. 

Note that if there are multiple redirect boxes on the path that allows a 

successful connection, then the one closest to the check mark has priority. Note 

also that those rules which do not change a value, I.e. if there is a rule which says 

for any address map port x to port y, then the address is not considered to be 
15 mapped and thus a redirect box further away from the check mark could rewrite 

that address (but not the port). If there is a rule further away which re maps the 

address and the port then that rule does not apply. 

One embodiment supports netmasks in the kernel. Such an embodiment 

masks the address to check with the netmask and check to see if it is the same as 
20 the check jxddr. If so (and providing there is a port match) we have a match. 

Thus the check jxddr and the netmask must match. 

MAT nodes 

These are nodes that handle MAT address on a single region interface. 

25 The GUI system allows the user to configure different behaviors depending on 
which address the connection came to the firewall on. To handle this the backend 
needs to put a MAT node as the node the service points to for those regions that 
have MATs. For example, if the user enables a service From "region 1" to 
To " Firewall via address a " , then a MAT node is needed. We only 

30 need MAT nodes for the firewall region provided that MAT has been defined for 
the firewall in that region. 

If an ACL check comes to a MAT node and if the destination address is 
not found in the list of addresses then the connection is denied. 
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The structure used is: 



struct scc_mat_rec { 

int num_mat_addrs ; 

struct sockaddr_in *mat_addrs ; 

scc_decision_node **next_node ; 

}; 



In one embodiment, there is a hash table that stores pointers to the 

10 decision nodes. The hash table consists of pointers to linked lists. The string is 
hashed to a bucket in the table and each bucket is the start of a linked list. A 
node when added to the table, the table is checked to see if the name is unique by 
looking at the string in the linked list that the string hashes to. If it is unique, 
then the node is added to the front of the hash table and if the node is already 

15 present, an EEXIST error is returned. 

The hashing algorithm used is the sum of the characters in the name 
modulo the size of the table. Currently the table is static in size and is set to 
A CL^HASHJTABLEJSIZE (i.e. 200 buckets). 

All initialization is done using the sccjiash^init function which is called 

20 by scc_acl_init. The size of the hash table is stored in scc_d_nodeJiash_size 
and the table itself is stored in sccjijiodejable. 

Counters need to be kept consistent (i.e. correct) even when a process 
that holds a connection dies. There are several ways to do this. The current 
approach is to use the proc structure of the process making the system call. A 

25 new field will be added to keep track of each counter used by that process and 
the number of concurrent uses of the counter. When the process dies, then the 
exit! code in the kernel will go through and clear the counters and free the proc 
space. 

In order to make sure that memory is not freed before a process is 
30 finished with it, we have a nodejiasjbeenjieleted flag. This flag is part of 
every counter and is set to true (i.e. not zero) if the counter is no longer in use 
and zero otherwise. If a process decrements a current count to zero and if the flag 
is set to true, then the memory is freed since no process is using that memory. If 
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a flag is set to true and the current count is already zero, then the memory is 
freed up immediately. 

The following describes one embodiment of the proc structure entry for 
the counters. First, we have a linked list of counters based on a connection. The 
5 entry in the proc structure is: scc_ACL_cell *scc_ACL_head; Each cell in this 
linked list is as follows: 

struct scc_ACL_cell { 

scc_ACL_cell *next ; 
s c c_AC L__c ell * p r e v ; 
scc_service_rec *service_record; 
int number__of_counters ; 

int *counter_type; /* shared or otherwise 

*/ 

void **counter_rec; 
} 

The connection id passed back to the proxy will be the actual pointer to 
the scc_ACL_celh Thus when the proxy does its free, we can very easily free up 
20 the counter space, free the memory, and re-attach the linked list of connection 
information. 

When a process exits, we check the linked list of ACL rules and free up 
any that are still in use by the process. 

When a new process starts up, we set the scc_ACL_head to NULL. 
25 When a process forks, the child's scc__ACL_head is set to NULL. 



10 



15 



In The Proxy 

The proxy will make two calls to the ACLs. The first call is: 

30 

int scc_is_service_allowed ( 

unsigned long service_number, 
struct sockaddr_in *src_ip, 
struct sockaddr_in *dst_ip, 
35 char *src_host_name, /* usually null */ 

char *dst_host_name, /* usually null */ 

char *user name, /* null if none */ 
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int name valid, /* tell if name is valid 



/* return values */ 
int &to_region; 
5 int &f roar region ; 

int &f ilter_text_len, 
char &f ilter_text , 
int rule_name_ len, 
char &rule_name, 
10 struct sockaddr_in &redirect_src_addr_uort, 

struct sockaddr_in &redirect__dst_addr_port , 
.•int &master_key, 
caddr_t &connection_id /* id for this 
connection */ 
15 ) ; 



The possible return values are: 



# define ACLJDENY 0 

20 #define ACL_ALLOW_HIDE_SRC 1 
#define ACL_ALLOW_HIDE_DST 2 
ttdefine ACL^ALLOW_HIDE_BOTH 3 
#define ACL^ALLOW__SHOW_ALL 4 
tfdefine ACL_RESOLVE_SRC_ADDR 5 

25 #define ACL_RESOLVEJDST_ADDR 6 

#define ACL_NEED_MORE_FILTER_SPACE 7 
#def ine ACL NEED USER NAME 8 



Thus the ACLs will return, for each connection, how to hide the 
30 addresses. The description of each of these values is as follows: 



service number: 



35 src_ip: 
dst_ip: 

src host name: 



40 



this is a number that the backend decides and is unique per 
service or possibly per service, from and to region triplet 
as desired. 

this is the source IP address of the connection, 
this is the destination IP address of the connection, 
this is the host name based on the reverse lookup of the 
source address of the connection. This is generally only 
used when the kernel explicitly asks for it by returning 
from a previous call to scc_js_service_allowed with a 
return value of A CL_RESOL VEJSRC ADDR. 
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dst host name: 



user name: 



name valid: 



tojregion: 
from_region: 
filter text len: 



30 filter text: 



rule name len: 



44 

this is the host name based on the reverse lookup of the 
destination address of the connection. This is generally 
only used when the kernel explicitly asks for it by 
returning from a previous call to sccjs_service_allowed 
with a return value of ACLJtESOLVEJ)ST_ADDR. 
this is the user name of the person using the service. This 
value is only used when ACLJIEEDJJSERJfAME has 
been returned by the kernel. Use NULL, if the name has 
not yet been requested. Currently only FTP, telnet and 
WWW support user names. 

this tells the ACLs whether or not a user name makes any 
sense for this protocol. If the name_yalid flag is set to 
TRUE, then user decision nodes will be used (and thus a 
user name will be required if a user decision node is 
encountered when checking the ACL). If set to false, then 
the user decision nodes will be ignored and the true path 
of those nodes encountered when checking the ACL will 
be used. 

the region number that the destination address of this 
connection is in. 

the region number that the source address of this 

connection is in. 

this is a pointer to an integer which has the length 
of the filter Jext array in it. This value will be set 
to the amount of data returned by the access call on 
return. If the return value is 
ACL_NEED_MORE_FILTERJSPACE, then the 
value in this variable will contain the amount of 
space required. 

this is an array of characters of size filter Jext Jen which 

will be used to store the concatenated filter strings 

accumulated while checking the ACLs. 

this is the size of the array rulejtame. 
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rulejiame: this is the name of the rule that allowed or denied the 

connection. Only a maximum of rulejiame Jen - 1 
characters will be stored in there. 
redirect_dst_addr_port: this is the address and port to redirect this 
5 connection to. The system will set this to all zeroes 

if it is not in use. The port and address will always 
both be set together in this structure if it is to be 
used. Only the sin _por/and sinjxddr part of the 
structure will be used. 
1 0 redirecMsrc__addr_port: this is used to indicate to the firewall that when 

making the connection from the firewall to the 
destination, it should use the source address/port 
provided. Note that unlike the 
redirect _dst_addr j)ort field only the parts of the 
1 5 address required will be filled out. In particular, if 

the port is specified but not the address then the 
address field will be zero. Similarly, if the address 
is specified but not the port, then the port will be 
zero. For the redirect jbt_addr _port y if one or 
20 both field are specified then they are both returned 

(with the unspecified field left the same as the 
actual destination), 
master-key: this is the key that indicates which items have been 

licensed on the firewall. 
25 connectionjd: this is the connection id for this connection. When 

the service is finished you provide this id to the 
sccjservicejdone system call and that function 
decrements the correct counters. 



30 Note that the user name will be used by the system to get the groups 

automatically behind the scenes in the library call. This means that the actual 
call to the kernel will have more fields. In particular, there will be a list of group 
names and a counter to indicate how many elements are in the list. 
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The second call will be: 

int scc_service_done(caddr_t connectionjd); 

5 This call always returns zero now. The kernel will use the information in 

the proc structure for this process to decrement the connection counts for this 
connection. 

There is one other call that a proxy might have to make. When an ACL is 
updated, proxies have to recheck their connections to see if they can still make 
10 the connection. This is done as follows: 



int 



15 



scc_recheck_service { 
unsigned long service_number , 
struct sockaddr_in *src_ip, 
struct sockaddr_in *dst_ip, 
char *src_host_name, 
char *dst_host_name, 
char *user_name, 
int n^me valid, 



/* 
/* 



/* 
/* 
null 
tell 



usually null */ 
usually null */ 
if none */ 
if name is valid 



20 



7 



id 



/* id for this 



25 



30 



c addr_t &c onne c t i on_ 
connection */ 

/* return values */ 
int &to_region; 
int & f r om_r eg i on ; 
int &f ilter_text_len, 
char &f ilter_text, 
int rule_name_len, 
char &rule_name, 

struct sockaddr_in &redirect_src_addr_port , 
struct sockaddr_in Scredirect_dst_addr_port , 
int fcmasterjcey 
) ; 



35 Returns from this will be the same as for the sccJs_service_allowed call except 
that connectionjd is passed in as a parameter not a return value. 

If the connection is not allowed, then the counters are automatically freed 
up and the proxy need not make any further calls for that connection. In the case 
of counter nodes, the recheck will fail until the counter is at an acceptable level. 

40 This means that, if the counter has been decreased below current connection 
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levels, the first connection rechecked will fail and so on until the current number 
of connections counter has been decremented enough. Thus, proxies should 
recheck services in order of lowest priority to highest priority (typically by 
checking the oldest sessions first, when that is possible). Note that short-lived 
5 proxies and servers started by secured cannot guarantee the order in which ACLs 
will be rechecked, since they will all get a HUP signal at the same time. 

In one embodiment, the backend is able to add, change, delete decision 
nodes. It also is able to insert new nodes into the tree. In such an embodiment, 
the following functions are provided to allow this to be done efficiently. All 

10 backend calls return 0 for success and - I for failure. Later, errno will be used to 
determine what went wrong. 

The Adding New and Updating Nodes call is used to add or update a 
node. The same call is used to add a new node or update a node. If the 
nodejlescriptor is unique, then it is a new node, otherwise update the node. In 

15 both cases, the values must all be completely filled out. 



int scc_set_user_node ( 

char *node_descriptor, 
char **sorted_ user_array, 
20 int number_of_users, 

char *true_child_node__descriptor, 
char *false_child_node_descriptor) 



25 int scc_set___host_node ( 

char *node__descriptdr , 

int type, /* sre or dst check */ 

char **sorted_hostname_array, /* see below */ 

int number_pf _names , 
30 struct sockaddr_in *ip_addr, /* array of structs 

of ip addrs */ 

struct sockaddr_in *ip_mask, /* array of structs 
of ip masks */ 

int number_of_ip, 
35 char *true_child_node_descriptor, 

char *false_childjaode_descriptor) ; 



Note that the list of host names must be in sorted order but the letters of 
the hostname must be reversed. For example, rafaeitor.securecomputing.com 
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would be moc.gnitupmoceruces.roLleafar. These are then put into sorted order. 
This allows the kernel to quickly process wild card entries. It is also important 
that unneeded entries are not loaded into the kernel. For example if the user has 
specified * com, then no other entries of the form .com should be present in the 
5 list passed to the kernel. 

int scc_set_ count_node ( 

char *node__ descriptor, 

int service^specif ic_f lag, /* share or not */ 
10 int max_count, 

char *true_child_node_descriptor , 
char *f alse_child_node_descriptar) ; 

int scc_set_time_node ( 
15 char *node_descriptor , 

scc_date_detail_rec *date_entries, 
int number_date_entries, 
char *true_childjnode_descriptor, 
char *false__child_node_descriptor) ; 



Note that the date records must be in sorted order using start ^seconds as the key 
to sort on. Note also that the date_entries field is an array obstructs. 



int scc_set_f ilter_node ( 
25 char *node_descriptor , 

char *f ilter_string, /* list of filters 

*/ 

unsigned long filter_string_lengt.il, 
char *child_node_descriptor) ; 

30 

int scc_set_log_node ( 

char *node_descriptor, 

int audit_jnessage_type, /* category of audit 
call */ 

35 char *log_message, /* message to output */ 

char *child_node_descriptor) ; 

int scc_set_rewrite_node ( 

char *node_descriptor, 
40 int src_dst_f lag, 

int no_ match__action, 
int number_of_rewrite_rules, 
scc_rewrite_rule *rewrite_rules, 
char *child__node_descriptor) ; 



wo 
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int scc_ set__subrule_ node ( 

char *node_descriptor, 

char *subrule_head_descriptor, /* start of 
sub rule */ 

5 char *true_child_node_descriptor , 

char *f alse_child_node_descriptor, /* NULL for 
service_rec */ 
); 

10 int scc_set_mat_node ( 

int num_mat_addrs / 

struct sockaddr_in *mat_addrs, /* array of 

structs */ 

char **node_descriptors) ; 



15 



20 



Note that for the scc_set_mat_node system call, the two arrays must be 
in sync (i.e. the first MAT address uses the first decision node in the node 
descriptors array). 

Return values from these are as follows: 



EEXIST: there is already a node with this nodejlescriptor and it is 
different from the node required for the system call. 

ENOMEM: happens when the kernel is out of memory. 

ENOENT: happens when the node descriptor specified does not exist. 
25 EINVAL: happens when an invalid argument is provided to a system call. 

One example is if a NULL truej:hildjiode_descriptor is passed 
in as an argument. 



int scc < _set_ service__node ( 
30 unsigned long service_number , /* made up by 

backend */ 

int to_region, 
int from_region, 
char *node_descriptor, 
35 int node_debug, 

char *child_node_descriptor) ; 



The service nodes are different from the other nodes. The reference is the 
service number not the node descriptor. The node descriptor is there for audit 
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purposes and should be the name of the ACL rule. If a debug value is set here 
then debugging is turned on recursively down the tree. 

For all nodes, the descriptor to use for the allow terminating node is the 
string _SCC_ALLOW. For the deny connection terminating node, use the string 
5 JSCCJ)ENY. 



Linking Nodes 

Nodes are linked in the same system call that they are built or updated 
from. Those nodes which only have one path through them only have one 
10 potential node leaving them. A child node can either be, a descriptor of an 
existing node, the string _SCC_ALLOW, or the string JSCCJDENY. 
_SCC_ALLOW and _SCCJ)ENYzxe the accept and deny terminals of the tree 
respectively and otherwise the child is another sccjdecision_node. 

If the child node desired does not exist the system will return an error. 

15 

Deleting Nodes 

If you want to delete a node you use: 

int scc_delete_node(char *node_descriptor); 

20 

for all nodes except service nodes. For service nodes you use: 

int scc_delete_service ( 
int service_number, 
25 int to_region, 

int f rom_jregion) ; 



Note that this will mark the node as deleted. You must still rebuild the tree. If an 
ACL is checked and a deleted node is encountered then the ACL will be denied. 
30 Also, the system will only delete nodes when the reference count to that 

node is zero. All deleted nodes will be removed from the decision node table 
when the system call is made though. 

If you want to delete the service from all regions, then set the source and 
destination regions to -1; 
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Debugging Nodes 

You can set the debug value of a node ( debug jxode field in the 
sccjdecisionjtode structure) by ORing bits. The possible values are: 



5 tfdefine SCC_ACL_DEBUGJTRUE 0x1 
#define SCC_ACL_DEBUG_FALSE 0x2 
tfdefine SCC_ACL_DEBUGJTIME 0x4 

If the SCC_ACL_DEBUG_TRUE bit is set, then print a debug message when a 
10 true decision is reached at this node of the form: 



audit_j?rintf ( 

AUD I T_F_KERN_ACL , 
AUDIT_A_AREA, 
15 AUDI T_T_DEBUG , 

AUDIT_P_MINOR, 

"ACL node: %s returned true.", 
d_node - >node_de scrip tor) ; 

20 If the StC_ACLJ)EBUG_FALSE bit is set,, then print a debug message 

when a false decision is reached at this node of the form: 



audit_printf ( 

AUDIT_F_KERN_ACL , 
25 AUD I T_A_AREA , 

AUDIT_T_DEBUG, 
AUDIT_P_MINOR, 

"ACL node: %s returned false. n # 
d_node->node_descriptor) ; 

30 

If the SCCjlCL_DEBUG_TIME bit is set, then print a debug message 
telling how much time was spent in this node in the form: 



audit_printf ( 
35 AUD I T JF JKERN_ACL , 

AUDIT_A_AREA, 
AUDIT JT_DEBUG, 
AUDIT_P_MINOR, 

"\n\nNode \ H %s\ ,f took %ld seconds and %ld 
40 mi croseconds \n " 
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"Children took %ld seconds and %ld 
microseconds . \n" , 

d_node->node_descriptor, 

end.tv_sec, end. tv_ usee, end_sub . tv_sec, 
5 end_sub . tv_usec) ; 

This will include all the time spent in subnodes as well. 

You can set the debugging value of a node using a separate system call: 

10 int scc_set_debug ( 

char *node_descriptor , 
int debug_yalue) ; 

For service nodes you should set the debug value in the set system call, 
15 Use the same possible values as above. 

Service Usage Statistics 

In one embodiment, the ACLs keep track of service counts for all 
services that use (hem. The counts are by service number, from region, to region 
20 triplet. Because we do not know before hand how many services there will be we 
implement this function in a two call method. A system call which could be 
used is as follows: 

int scc_cjet_service__counts ( 
25 int calltype 

int *count_size, 

struct scc_serv_count *counts) ; 

The calltype can be one of: 

30 

#define SCC_GET_NUM 0 
#define SCC_GET_VALS 1 

When called with calltype =3D=3D SCC__GET_NUM, this system 
35 call sets the value of count _size to be the number of elements that need to be 
allocated in the counts array; 
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When called with call type =3D=3D SCC_GET_VALS, this system 
call sets the entries in the counts array to the appropriate values. If for some 
reason the number of elements in the array counts, passed in count _size is not 
big enough, then the call returns with ENOSPC and passes the new number 
5 required back in count jsize. Even if there is enough space, we return in 
count jsize the number of array elements used. 

Each entry in the counts array is defined as follows: 



typedef struct { 
10 unsigned long serv; /* service number 

*/ 

int from; /* from region */ 

int to; /* to region */ 

unsigned long total_sessions ; /* since last 
15 reboot */ 

unsigned long current_sessions ; /* current active 

■*/ 

} scc_serv_count; 



20 rnnrlnsinn 

It is understood that the above description is intended to be 
illustrative, and not restrictive. Many other embodiments will be apparent to 
those of skill in the art upon reviewing the above description. The scope of the 
invention should, therefore, be determined with reference to the appended 
25 claims, along with the full scope of equivalents to which such claims are entitled. 
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What is claimed is: 

1. A method of implementing a security policy, comprising the steps of: 
providing a plurality of access policies; 

defining a process; and 

connecting the access policies and the process to form a security policy. 

2. The method according to claim 1 , wherein the step of defining a process 
includes the step of creating an alert. 

3. The method according to claim 1 , wherein the step of defining a process 
includes the step of adding a filter. 

4. The method according to claim 3, wherein the filter is a URL blocking 
filter. 

5. In a computer network having a plurality of separate networks, an access 
control mechanism comprising; 

a plurality of regions, including a first and a second region; 

one or more services bridging said first and second region; 

access control rules which define a security policy, wherein the access 
control rules limit data transfer by the one or more services bridging the first and 
second regions, wherein the access control rules are defined as a decision tree, 
wherein the decision tree includes a decision node and a first and a second 
branch and wherein the decision node includes a true and a false destination 
path, wherein the true destination path leads to the first branch and the false 
destination path leads to the second branch; and 

access control logic, wherein the access control logic operates with the 
access control rules to enforce the security policy. 

6. The access control mechanism according to claim 5, wherein the first and 
the second branches lead to other decision nodes. 
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7. The access control mechanism according to claim 5, wherein the decision 
tree further includes a filter, wherein the first branch leads to the filter. 

8. The access control mechanism according to claim 5, wherein the first and 
the second branches lead to other decision nodes. 

9. In a computer network system having a plurality of networks and a 
plurality of services, including a first service, wherein each service defines a 
protocol for transferring data between two of the plurality of networks, a method 
of limiting transfers between networks, comprising the steps of: 

defining a to-from set, wherein the to-from set lists a source network and 
a destination network; 

associating the to-from set with the first service; 

defining a path, wherein the path includes desired options for limiting 
transfer from the source network to the destination network via the first service; 

storing information regarding the to-from set, the first service and the 
path as an access control rule; 

receiving a request to set up said first service between the source network 
and the destination network; 

comparing the request to the access control rule to determine access; and 

if access is allowed, establishing the service between the source and 
destination networks. 

10. In a computer network system having a plurality of networks and a 
plurality of services, including a first service, wherein each service defines a 
protocol for transferring data between two of the plurality of networks, a method 
of defining a security policy, comprising the steps of: 

defining a plurality of access policies, including a first and a second 
access policy, wherein the step of defining includes the step of creating a 
plurality of access policy routines, including a first and a second access policy 
routine, wherein the first access policy routine embodies the first access policy 
and wherein the second access policy routine embodies the second access policy; 
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forming a decision tree having a plurality of decision nodes, including a 
first, second and third decision node, wherein the first and second decision nodes 
enforce the first access policy and wherein the third decision node enforces the 
second access policy; and 

compiling a list of access control rules, wherein the step of compiling 
includes the step of replacing each decision node with one of the plurality of 
access policy routines. 

11. In a computer network system having a plurality of networks and a 
plurality of services, including a first service, wherein each sendee defines a 
protocol for transferring data between two of the plurality of networks, a method 
of enforcing a security policy, comprising the steps of: 

defining a plurality of regions, including a first and a second region; 

assigning each network to a region; 

defining a first and a second service; 

defining a plurality of access policies, including a first and a second 
access policy, wherein the first access policy limits communication between the 
first and second region using the first service and wherein the second access 
policy limits communication between the first and second region using the 
second service, wherein the step of defining includes the step of creating a 
plurality of access policy routines, including a first and a second access policy 
routine, wherein the first access policy routine embodies the first access policy 
and wherein the second access policy routine embodies the second access policy; 

forming a decision tree having a plurality of decision nodes, inqluding a 
first, second and third decision node, wherein the first and second decision nodes 
enforce the first access policy and wherein the third decision node enforces the 
second access policy; 

compiling a list of access control rules, wherein the step of compiling 
includes the step of replacing each decision node with one of the plurality of 
access policy routines; 

receiving a packet from the first region; and 

accessing the list of access control rules to determine if the packet should 
be forwarded to the second region. 
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12. A method of achieving network separation within a computing system 
having a plurality of network interfaces, the method comprising the steps of: 

defining a plurality of regions; 

configuring a set of policies for each of the plurality of regions; 

assigning each of the plurality of network interfaces to only one of the 
plurality of regions, wherein at least one of the plurality of network interfaces is 
assigned to a particular region; and 

restricting communication to and from each of the plurality of network 
interfaces in accordance with the set of policies configured for the one of the 
plurality of regions to which the one of the plurality of network interfaces has 
been assigned. 

13. A secure server, comprising: 
an operating system kernel; 

a plurality of network interfaces which communicate with the operating 
system kernel; and 

a plurality of regions, wherein a set of policies have been configured for 
each of the plurality of regions; 

wherein each of the plurality of network interfaces is assigned to only 
one of the plurality of regions; 

wherein at least one of the plurality of network interfaces is assigned to a 
particular region; and 

wherein communication to and from each of the plurality of network 
interfaces is restricted in accordance with the set of policies configured for the 
one of the plurality of regions to which the one of the plurality of network 
interfaces has been assigned. 
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If either condition is not met, the packet is not forwarded. 
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Look at source IP address, source IP port, destination address, 
destination port, and check the region associated with the packet 
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sockets receive data originating only from the correct region. Are all 
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